<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>文章列表</title>
    <link rel="stylesheet" href="./libs/bootstrap/css/bootstrap.min.css">
    <link rel="stylesheet" href="./css/reset.css">
    <link rel="stylesheet" href="./css/iconfont.css">
    <link rel="stylesheet" href="./css/main.css">
    <script src="./libs/jquery-1.12.4.min.js"></script>
    <!-- 引入模板引擎js文件 -->
    <script src="./libs/template-web.js"></script>
    <!-- // .给页面添加分页插件 -->
    <script src="./libs/jquery.twbsPagination.js"></script>
    <script src="./libs/https.js"></script>
</head>

<body>
    <div class="container-fluid">
        <div class="common_title">
            文章列表
        </div>
        <div class="container-fluid common_con">
            <div class="row opt_btns">
                <div class="col-xs-6">
                    <form class="form-inline">
                        <select id="selCategory" name="" class="form-control input-sm">
                            <option value="">所有分类</option>
                            <option>未分类</option>
                            <option>奇趣事</option>
                            <option>会生活</option>
                            <option>爱旅行</option>
                        </select>
                        <select id="selStatus" name="" class="form-control input-sm">
                            <option value="">所有状态</option>
                            <option value="草稿">草稿</option>
                            <option value="已发布">已发布</option>
                        </select>
                        <button id="btnSearch" class="btn btn-default btn-sm">筛选</button>
                    </form>
                </div>
                <div class="col-xs-6">
                    <a href="article_release.html" class="btn btn-success btn-sm pull-right" id="release_btn">发表文章</a>
                </div>
            </div>
            <table class="table table-striped table-bordered table-hover mp20">
                <thead>
                    <tr>
                        <th>标题</th>
                        <th>作者</th>
                        <th>分类</th>
                        <th class="text-center">发表时间</th>
                        <th class="text-center">状态</th>
                        <th class="text-center" width="100">操作</th>
                    </tr>
                </thead>
                <tbody>
                    <tr>
                        <td>王积千造统最头</td>
                        <td>杰克</td>
                        <td>奇趣事</td>
                        <td class="text-center">2017-06-08 07:08:46</td>
                        <td class="text-center">已发布</td>
                        <td class="text-center">
                            <a href="article_edit.html" class="btn btn-default btn-xs">编辑</a>
                            <a href="javascript:void(0);" class="btn btn-danger btn-xs delete">删除</a>
                        </td>
                    </tr>
                </tbody>
            </table>
            <div class="row text-center">
                <!-- // .给页面添加分页插件容器标签 -->
                <ul id="pagination" class="pagination-sm"></ul>
            </div>
        </div>
    </div>
    <script type="text/html" id="tpl_list">
    {{each data.data v}}
    <tr>
        <td>{{v.title}}</td>
        <td>{{v.author}}</td>
        <td>{{v.category}}</td>
        <td class="text-center">{{v.date}}</td>
        <td class="text-center">{{v.state}}</td>
        <td class="text-center">
            <a href="article_edit.html?editor={{v.id}}" class="btn btn-default btn-xs" >编辑</a>
            <a   href="javascript:void(0);" class="btn btn-danger btn-xs delete" data-id='{{v.id}}'>删除</a>
        </td>
    </tr>
    {{/each}}
        </script>
</body>

</html>
<script src="./libs/https.js"></script>
<script type="text/html" id="tpl-category">
    <option value="">所有分类</option>
    {{each data v}}
    <option value="{{v.id}}">{{v.name}}</option>
    {{/each}}
</script>
<script>

    $(function () {
        $.ajax({
            type: 'get',
            url: BigNew.category_list,
            success: function (backData) {
                if (backData.code == 200) {
                    let htmlStr = template('tpl-category', backData)
                    $('#selCategory').html(htmlStr)
                }
            }
        })
        // 准备一个全局变量，来保存当前被选中的页码
        let selPage = 1
        // 3.封装函数 ：获得指定数据 ，渲染结构 
        function loadData(page) {
            $.ajax({
                type: 'get',
                url: BigNew.article_query,
                data: {
                    type: $('#selCategory').val(),
                    state: $('#selStatus').val(),
                    page: page,
                    perpage: 5
                },
                success: function (backData) {
                    console.log(backData);
                    if (backData.code == 200) {
                        if (backData.data.totalCount > 0) {



                            let htmlStr = template('tpl_list', backData)
                            $('tbody').html(htmlStr);




                            // 7.给页面添加分页插件方法

                            $('#pagination').twbsPagination('destroy')
                            $('#pagination').twbsPagination({
                                totalPages: backData.data.totalPage,
                                visiblePages: 10,
                                startPage: page,
                                initiateStartPageClick: false,
                                // 修改按钮的文本
                                first: '首页',
                                prev: "上一页",
                                next: '下一页',
                                last: '尾页',
                                onPageClick: function (event, page) {
                                    // 将当前页面变成全局变量
                                    selPage = page;
                                    // page:是当前 被点击的页码
                                    // 请求当前 被点击页码的数据 
                                    loadData(page)
                                }
                            })
                        } else {
                            //没有数据 ，
                            //tbody内容要清空，分页导航就不需要设置，文本提示
                            //empty()==html('')
                            $('tbody').empty()  //empty()是清空所有子元素
                            $('#pagination').html('当前类别没有任何数据 ，请重新筛选..');
                        }
                    }
                }
            })
        }
        loadData(1)

        // 6.设置筛选按钮点击事件
        $('#btnSearch').on('click', function (e) {
            e.preventDefault()
            loadData(1);
        })

        // 8.给所有删除按钮设置委托事件

        $('tbody').on('click', '.delete', function () {
            let dataid = $(this).attr('data-id');
            console.log(dataid);
            // 10发起ajax请求，删除指定的数据 
            $.ajax({
                type: 'post',
                url: BigNew.article_delete,
                data: {
                    id: dataid
                },
                success: function (backData) {
                    console.log(backData);
                    if (backData.code == 204) {
                        if ($('tbody>tr').length > 1 || selPage == 1) {
                            loadData(selPage);
                        } else {
                            loadData(--selPage);
                        }
                    }
                }
            })
        })
        // 点击发表页面按钮,让二级菜单被选中
        $('#release_btn').on('click', function () {
            // 找到父页面的二级菜单li标签(发表文章按钮,设置选中效果)
            parent.$('.level02 li').eq(1).click();
        })


    })
</script>